Data Communication

ABSTRACT

A method and apparatus for data communication in a variety of communication systems using spread spectrum techniques and multilevel sequences in which distinct multilevel sequences used contain binary subsequences that interfere constructively such that synchronous cross-correlation values add constructively. By adding two subsequences from different sets it is ensured that neither subsequence belongs to the same set this in combination with use of correlators reducing complexity, and facilitates increasing the order of a modulation scheme thus enhancing the bandwidth efficiency.

[0001] The present invention relates to data communication and more particularly, to data communication using spread spectrum techniques. The invention also relates to communication applications using multilevel sequences. For the purposes of this specification, a multilevel sequence is constructed by the superposition of a number of sequences.

[0002] Techniques of this type are used for information carrying signals in a variety of communication systems because of their ability to increase data throughput and to reduce the effects of certain transmission impairments including, but not limited to co-channel interference, multiple access interference and intersymbol interference. Local Area Networks (LANs) is one area in which there is an increasing need for wireless access. This allows mobile computer users to remain in contact with a given corporate LAN over short distances. Data transmission rates achievable with known solutions are relatively low limiting the range of potential applications.

[0003] The Institute for Electrical and Electronic Engineers (IEEE) has now formalized the 802.11 standard to help improve and promote the growth of Wireless LAN (WLAN) products however, the difficulties of transmission rates, reliability and cost remain. Spread spectrum communication techniques using multilevel sequences represents one possible solution however, it is difficult to synchronise data communication without the use of complex circuitry. Synchronisation difficulties include symbol synchronisation, chip synchronisation and signal strength measurements (SSM) as well as the problem of synchronisation maintenance.

[0004] There is therefore a need for a method and apparatus, which will overcome the aforementioned problems.

[0005] Accordingly, the invention provides a method and apparatus for data communication using spread spectrum techniques and multilevel sequences.

[0006] Preferably, the method utilises symbols, said symbols having a multilevel sequence constructed by adding together at least two subsequences taken from different sets thereby ensuring that neither subsequence belongs to the same set.

[0007] In one arrangement, the or each subsequence is a binary sequence.

[0008] Ideally, distinct multilevel sequences are selected for use which interfere constructively.

[0009] In one arrangement of the invention, detection of a symbol for demodulation is achieved using an M-ary receiver provided by a bank of M correlators wherein each M correlator is matched to a multilevel sequence.

[0010] Preferably, a greatest peak detector of size M is formed to detect the symbol transmitted. Thus, by exploiting the composite nature of the multilevel sequences, a substantial reduction in receiver complexity is achieved.

[0011] In a particularly preferred embodiment, a mulitlevel symbol is detected using a plurality of banks of correlators, each correlator being of a predefined length.

[0012] Ideally, each correlator output is subjected to linear addition and analysed to determine whether it corresponds to a valid subsequence. Thus, with every other correlator output that corresponds to a valid subsequence that is for each valid symbol the same M test statistics as those obtained when a bank of M correlators is used providing a significant reduction in the number of correlators. In addition to reducing complexity, the new scheme is readily amenable to increasing the order of the modulation scheme and thereby enhancing the bandwidth efficiency.

[0013] In a preferred arrangement, an amplitude modulation factor is used in accordance with, for example when just two sequences are added together,

{ã _(i) }=α{b _(i) }+β{c _(i)}

[0014] Ideally, the amplitude demodulation process incorporates means for discriminating between different symbols having similar greatest peak positions.

[0015] In another arrangement, the method is formed for detecting a symbol using m-banks of n-correlators wherein the length of each correlator is w.

[0016] Preferably, the method incorporates means for isolating a correlator output having the greatest peak from the bank of n correlators corresponding to the set from which the subsequence was taken.

[0017] Ideally, the method is carried out for each subsequence in the multilevel sequence. Thus, the receiver obtains m greatest peaks corresponding to m distinct correlators (one from each bank) which uniquely identifies the multilevel sequence transmitted.

[0018] Preferably, a lookup table is used to decode the k data bits that correspond to the detected multilevel sequence. Thus modulation is achieved with minimal correlators and only requires m greatest peak detectors each of size n; thereby reducing substantially the complexity of the maximum likelihood detection process.

[0019] According to another aspect of the invention, multilevel sequences are constructed by adding together subsequences taken from complementary sets of binary sequences.

[0020] Ideally the method is formed for identification of sequences having the following properties:

[0021] cyclically distinct;

[0022] possess low autocorrelation sidelobes;

[0023] possess low intra-crosscorrelation magnitudes; and

[0024] posess low inter-crosscorrelation magnitudes.

[0025] According to another aspect of the invention there is provided a method for data communication using spread spectrum techniques and multilevel sequences characterised in that selection distinct multilevel sequences used in the method contain binary subsequences that interfere constructively such that synchronous cross-correlation values add constructivly.

[0026] Preferably, the method utilises symbols, said symbols having a multilevel sequence constructed by adding together at least two subsequences taken from different sets.

[0027] Preferably, a subsequence is provided as a binary sequence.

[0028] Preferably, the method includes the step of detecting of a symbol for demodulation using an M-ary receiver.

[0029] Preferably, the M-ary receiver incorporates a bank of M correlators in which:

[0030] each M correlator is matched to a multilevel sequence; and

[0031] forming a greatest peak detector of size M is to detect the symbol transmitted.

[0032] Preferably, a mulitlevel symbol is detected using a plurality of banks of predefined length correlators.

[0033] Preferably, each predefined length correlator output is subjected to linear addition and analysed to identify a valid subsequence.

[0034] Preferably, the method utilises an amplitude demodulation process.

[0035] Preferably, the amplitude demodulation process incorporates means for discriminating between different symbols having similar greatest peak positions.

[0036] Preferably, a symbol is detected using m-banks of n-correlators of predefined length.

[0037] Preferably, the method incorporates means for isolating a correlator output having a greatest peak from the bank of n correlators corresponding to the set from which the subsequence was taken.

[0038] Preferably, a lookup table is used to decode data bits corresponding to a detected multilevel sequence.

[0039] Preferably, the multilevel sequences are constructed by adding together subsequences taken from complementary sets of binary sequences.

[0040] Preferably, the step of identifying sequences having the properties of being cyclically distinct and possessing:

[0041] low autocorrelation sidelobes;

[0042] low intra-crosscorrelation magnitudes; and

[0043] low inter-crosscorrelation magnitudes.

[0044] According to another aspect of the invention there is provided a data communications apparatus using spread spectrum techniques and multilevel sequences characterised in that the apparatus incorporates means for selection of distinct multilevel sequences containing constructively interfereing binary subsequences such that synchronous cross-correlation values add constructivly.

[0045] Ideally, the apparatus incorporates means for detecting of a symbol for demodulation using an M-ary receiver.

[0046] Ideally, the M-ary receiver incorporates a bank of M correlators in which:

[0047] each M correlator is matched to a multilevel sequence; and

[0048] forming a greatest peak detector of size M is to detect the symbol transmitted.

[0049] Ideally, a mulitlevel symbol is detected using a plurality of banks of predefined length correlators.

[0050] Ideally, each predefined length correlator output is subjected to linear addition and analysed to identify a valid subsequence.

[0051] Ideally, the apparatus includes an amplitude demodulator.

[0052] Ideally, the amplitude demodulator includes means for discriminating between different symbols having similar greatest peak positions.

[0053] Ideally, the means for detecting a symbolincludes m-banks of n-correlators of predefined length.

[0054] Ideally, the apparatus includes means for isolating a correlator output having a greatest peak from the bank of n correlators corresponding to the set from which the subsequence was taken.

[0055] Ideally, the apparatus includes a lookup table for decoding data bits corresponding to a detected multilevel sequence.

[0056] Ideally, the apparatus incorporates means for adding together subsequences taken from complementary sets of binary sequences to construct multilevel sequences.

[0057] The invention will now be described more particularly with reference to the accompanying drawings, which show, by way of example only, one embodiment of data communication method and apparatus according to the invention. In the drawings:

[0058]FIG. 1. shows a multilevel code keying scheme in accordance with the invention; and

[0059]FIG. 2. shows an M-ary Code keying Demodulation scheme.

[0060] To aid understanding of the current invention, a brief discussion of multilevel sequences is given. Letting m denote the number of sets of binary sequences used where each set contains n distinct sequences each of length w. Then a multilevel sequence is constructed by adding together m binary subsequences each taken from a different set. That is, no two subsequences belong to the same set. By subsequence is meant a binary sequence used in the construction of a multilevel sequence. The total number of multilevel sequences which can be constructed is equal to n^(m). In general, the n^(m) multilevel sequences may be used as symbols in an M-ary digital communication system where typically M=2^(k)=n^(m) and k is the number of data bits encoded by the M-ary modulation scheme. If the bandwidth efficiency of the M-ary scheme is defined by the ratio k/w, then bandwidth efficiencies of the order of unity can be achieved by this scheme while a good communication link performance is retained. Also, the transceiver complexity is only increased by a modest amount.

[0061] The following sequence notation has been adopted throughout

[0062] A binary biphase sequence {a_(i)} has elements a_(i)ε{−1,1}. For simplicity in the description of sequence generation hereinafter, the binary biphase notation a_(i)ε{−,+} is used where symbol “−” denotes a “−1” and the symbol “+” denotes a “+1”.

[0063] We denote a binary biphase sequence of length w by {a_(i)}=(a₀,a₁,a₂, . . . a_(w−1)) while {a^((x))} denotes a binary biphase sequences {a_(i) ⁽⁰⁾}, {a_(i) ⁽¹⁾}, {a_(i) ⁽²⁾}, . . . {a_(i) ^((x−1))} each of length w.

[0064] A multilevel sequence {ã_(i)} has elements ã_(i)εZ (i.e. the set of all integers) and we denote a multilevel sequence of length w by {ã_(i)}=(ã₀,ã₁,ã₂,ã_(w−1)) while {ã^((x))} denotes a set of multilevel sequences {ã_(i) ⁽⁰⁾}, {ã_(i) ⁽¹⁾},{ã_(i) ⁽²⁾}, . . . {ã_(i) ^((x−1))} each of length w.

[0065] A Multilevel Code Keying (MCK) modulation scheme in accordance with the invention is now described with reference to the use of multilevel sequences.

[0066] In the method of the invention, k binary data bits are used to encode 2^(k) symbols where a symbol is a multilevel sequence constructed according to the principle described above.

[0067] MCK is an M-ary scheme dimensioned such that 2^(k)≦n^(m), that is, there can be more multilevel sequences than symbols. Thus 2^(k) multilevel sequences are selected from the total set of n^(m) multilevel sequences according to a predefined selection process. The 2^(k) multilevel sequences thus selected are assigned to be symbols in the M-ary scheme. FIG. 1 shows a schematic diagram of an MCK modulation scheme.

[0068] Symbol selection can be based on a number of different methods. The underlying principle behind these methods being the selection of distinct multilevel sequences which contain binary subsequences that interfere constructively. That is, their synchronous cross-correlation values add in a constructive manner rather than a destructive one. A method for choosing multilevel sequences with good properties is an important feature of the current invention and is described below.

[0069] Referring now to FIG. 2 there is shown a demodulation scheme in accordance with the invention. At the receiver the detection of a symbol can be done in one of two ways. One way is to use a conventional M-ary receiver which consists of a bank of M correlators, each matched to a multilevel sequence, and a greatest peak detector of size M that detects the symbol transmitted. By exploiting the composite nature of the multilevel sequences, a substantial reduction in receiver complexity can be realised in this scheme. A mulitlevel sysmbol can be detected by using m-banks of n-correlators where the length of each correlator is w. The linear addition of each correlator output that corresponds to a valid subsequence with every other correlator output that corresponds to a valid subsequence (i.e. for each valid symbol) gives the same M test statistics as those obtained when a bank of M correlators is used. The M test statistics are fed to a greatest peak detector of size M as usual. This new scheme requries just mn correlators instead of the M correlators used in a conventional M-ary scheme.

[0070] Inaddition to reducing complexity, the new scheme is readily amenable to increasing the order of the modulation scheme and thereby enhancing the bandwidth efficiency. This is done by introducing an amplitude modulation factor when subsequences are combined as illustrated by

{ã _(i) }=α{b _(i) }+β{c _(i)}

[0071] The coefficients {α,β} may be positive integers and the number of available symbols depends on the range of values of {αβ}. For example, when α,β,ε{1,2},m=2 and n=w=4 then the total number of available multilevel sequences in 64 instead of 16 when amplitude modulation is not used. When amplitude modulation is used then the same symbol detection schemes described earlier can be used. However, an extra signal processing step is required at the correlator outputs in order to discriminate between different symbols that have the same greatest peak position but different greatest peak magnitudes due to the amplitude modulation effect.

[0072] In the second scheme, a symbol is detected by using mn-banks of n-correlators where the length of each correlator is w. Since a multilevel sequence consists of m subsequences, one taken from each of the m sets, then a subsequence is detected, in a maximum likelihood sense, by choosing the correlator output with the greatest peak from the bank of n correlators corresponding to the set from which the subsequence was taken. This procedure is carried out for each subsequence in the multilevel sequence. Consequently, the receiver obtains m greatest peaks corresponding to m distinct correlators (one from each bank) which uniquely identifies the multilevel sequence transmitted. Finally, a lookup table is used to decode the k data bits that corrspond to the detected multilevel sequence.

[0073] The second scheme offers a number of advantages over the first scheme, thereby making it the preferred choice in most partical applications. Like the first scheme, the second only requires nm correlators. Unlike the first scheme, which requires a single greatest peak detector of size M, the second only requires m greatest peak detectors each of size n; thereby reducing substantially the complexity of the maximum likelihood detection process. In addition, the BER versus E_(b)/N_(o) performance of the second scheme is similar to that of the first scheme since for both schemes the distances between the greatest peak and its nearest neighbours are similar. That is, both detection methods give almost the same performances.

[0074] The Multilevel Code Keying scheme described above is illustrated by way of example when m=2 and n=w=4. Two subsequence sets {b⁽⁴⁾} and {c⁽⁴⁾} are selected as illustrated in Table 1. TABLE 1 MCK Subsequence Sets {b⁽⁴⁾} {c⁽⁴⁾} {b_(i) ⁽⁰⁾} + + + − {c_(i) ⁽⁰⁾} + + + + {b_(i) ⁽¹⁾} + + − + {c_(i) ⁽¹⁾} + − + − {b_(i) ⁽²⁾} + − + + {c_(i) ⁽²⁾} + + − − {b_(i) ⁽³⁾} − + + + {c_(i) ⁽³⁾} + − − +

[0075] Then a set of multilevel sequences is constructed by the addition of every sequence in {b⁽⁴⁾} with every sequence in {c⁽⁴⁾} as illustrated in Table 2. For the example given, there are 4²(=16) multilevle sequences each of length w=4.

[0076] In this example, the multilevel sequences {ã_(i) ⁽³⁾}, {ã_(i) ⁽⁵⁾} and {ã_(i) ⁽¹⁰⁾} are not distinct, and therefore symbols must be selected from a set of 14 rather than 16 multilevel sequences. A subset of eight symbols is selected by choosing eight multilevel sequences with greatest peak values at the correlator outputs. That is, the symbol set chosen is {{ã_(i) ⁽⁰⁾}, {ã_(i) ⁽¹⁾}, {ã_(i) ⁽²⁾}, {ã_(i) ⁽⁴⁾}, {ã_(i) ⁽⁶⁾}, {ã_(i) ⁽⁷⁾}, {ã_(i) ⁽⁸⁾}, {ã_(i) ⁽⁹⁾}} and the corresponding greatest peak values at the correlator outputs are {6,6} in all cases. In addition to the set given, multilevel sequences {ã_(i) ⁽¹¹⁾} and {ã_(i) ⁽¹²⁾} could have been chosen according to the greatest peak criterion. In general, each multilevel sequence is not necessarily distinct, though the number of distinct multilevel sequences is increased when each subsequence is cyclically distinct. Furthermore, each multilevel sequence is not necessarily cyclically distinct, though the number of cyclically distinct multilevel sequences is increased when long, cyclically distinct subsequences are used. TABLE 2 MCK Multilevel Sequences {a⁽¹⁶⁾} {ã_(i) ⁽⁰⁾} {(b_(i) ⁽⁰⁾} + {c_(i) ⁽⁰⁾} 2 2 2 0 {ã_(i) ⁽¹⁾} {(b_(i) ⁽⁰⁾} + {c_(i) ⁽¹⁾} 2 0 2 −2 {ã_(i) ⁽²⁾} {(b_(i) ⁽⁰⁾} + {c_(i) ⁽²⁾} 2 2 0 −2 {ã_(i) ⁽³⁾} {(b_(i) ⁽⁰⁾} + {c_(i) ⁽³⁾} 2 0 0 0 {ã_(i) ⁽⁴⁾} {(b_(i) ⁽¹⁾} + {c_(i) ⁽⁰⁾} 2 2 0 2 {ã_(i) ⁽⁵⁾} {(b_(i) ⁽¹⁾} + {c_(i) ⁽¹⁾} 2 0 0 0 {ã_(i) ⁽⁶⁾} {(b_(i) ⁽¹⁾} + {c_(i) ⁽²⁾} 2 2 −2 0 {ã_(i) ⁽⁷⁾} {(b_(i) ⁽¹⁾} + {c_(i) ⁽³⁾} 2 0 −2 2 {ã_(i) ⁽⁸⁾} {(b_(i) ⁽²⁾} + {c_(i) ⁽⁰⁾} 2 0 2 2 {ã_(i) ⁽⁹⁾} {(b_(i) ⁽²⁾} + {c_(i) ⁽¹⁾} 2 −2 2 0 {ã_(i) ⁽¹⁰⁾} {(b_(i) ⁽²⁾} + {c_(i) ⁽²⁾} 2 0 0 0 {ã_(i) ⁽¹¹⁾} {(b_(i) ⁽²⁾} + {c_(i) ⁽³⁾} 2 −2 0 2 {ã_(i) ⁽¹²⁾} {(b_(i) ⁽³⁾} + {c_(i) ⁽⁰⁾} 0 2 2 2 {ã_(i) ⁽¹³⁾} {(b_(i) ⁽³⁾} + {c_(i) ⁽¹⁾} 0 0 2 0 {ã_(i) ⁽¹⁴⁾} {(b_(i) ⁽³⁾} + {c_(i) ⁽²⁾} 0 2 0 0 {ã_(i) ⁽¹⁵⁾} {(b_(i) ⁽³⁾} + {c_(i) ⁽³⁾} 0 0 0 2

[0077]FIG. 2 shows a schematic diagram of the MCK receiver which uses m=2 banks of correlators each containing n=4 correlators. One correlator bank is matched to the binary subsequence set {b⁽⁴⁾} while the other is matched to {c⁽⁴⁾}. The correlator output values are shown for the transmitted multilevel symbol {ãhd i⁽⁴⁾}={2, 2, 0, 2}. The MCK scheme presented in this example uses eight symbols (i.e. 8-ary MCK) and is capable of encoding k=3 data bits per symbol. Therefore, the bandwidth efficiency of the scheme is equal to 0.75 (i.e. k/w). Furthermore, a total of nm=8 correlators is required at the receiver.

[0078] In addition to MCK, it is possible to define Multilevel Bi-Code Keying (MBCK). In MBCK the multilevel sequences are constructed by adding together subsequences taken from complementary sets of binary sequences. By complementary set is meant a set of 2n binary sequences each of length w where one half of the set is the complement of the other half. An MBCK encoding scheme may be illustrated by way of example when m=2, n=4 and w=4. The two sets of binary subsequences used in the illustration of MCK are reused here but now include their complementary sequences as shown in Table 3. TABLE 3 MBCK Subsequence Sets {b⁽⁸⁾} {c⁽⁸⁾} {b_(i) ⁽⁰⁾} + + + − {c_(i) ⁽⁰⁾} + + + + {b_(i) ⁽¹⁾} + + − + {c_(i) ⁽¹⁾} + − + − {b_(i) ⁽²⁾} + − + + {c_(i) ⁽²⁾} + + − − {b_(i) ⁽³⁾} − + + + {c_(i) ⁽³⁾} + − − + {b_(i) ⁽⁴⁾} − − − + {c_(i) ⁽⁴⁾} − − − − {b_(i) ⁽⁵⁾} − − + − {c_(i) ⁽⁵⁾} − + − + {b_(i) ⁽⁶⁾} − + − − {c_(i) ⁽⁶⁾} − − + + {b_(i) ⁽⁷⁾} + − − − {c_(i) ⁽⁷⁾} − + + −

[0079] TABLE 4 MBCK Multilevel Sequences {a⁽⁶⁴⁾} {ã_(i) ⁽⁰⁾} 2 2 2 0 {ã_(i) ⁽¹⁶⁾} 2 0 2 2 {ã_(i) ⁽³²⁾} 0 0 0 2 {ã_(i) ⁽⁴⁸⁾} 0 2 0 0 {ã_(i) ⁽¹⁾} 2 0 2 −2 {ã_(i) ⁽¹⁷⁾} 2 −2 2 0 {ã_(i) ⁽³³⁾} 0 −2 0 0 {ã_(i) ⁽⁴⁹⁾} 0 0 0 −2 {ã_(i) ⁽²⁾} 2 2 0 −2 {ã_(i) ⁽¹⁸⁾} 2 0 0 0 {ã_(i) ⁽³⁴⁾} 0 0 −2 0 {ã_(i) ⁽⁵⁰⁾} 0 2 −2 −2 {ã_(i) ⁽³⁾} 2 0 0 0 {ã_(i) ⁽¹⁹⁾} 2 −2 0 2 {ã_(i) ⁽³⁵⁾} 0 −2 −2 2 {ã_(i) ⁽⁵¹⁾} 0 0 −2 0 {ã_(i) ⁽⁴⁾} 0 0 0 −2 {ã_(i) ⁽²⁰⁾} 0 −2 0 0 {ã_(i) ⁽³⁶⁾} −2 −2 −2 0 {ã_(i) ⁽⁵²⁾} −2 0 −2 −2 {ã_(i) ⁽⁵⁾} 0 2 0 0 {ã_(i) ⁽²¹⁾} 0 0 0 2 {ã_(i) ⁽³⁷⁾} −2 0 −2 2 {ã_(i) ⁽⁵³⁾} −2 2 −2 0 {ã_(i) ⁽⁶⁾} 0 0 2 0 {ã_(i) ⁽²²⁾} 0 −2 2 2 {ã_(i) ⁽³⁸⁾} −2 −2 0 2 {ã_(i) ⁽⁵⁴⁾} −2 0 0 0 {ã_(i) ⁽⁷⁾} 0 2 2 −2 {ã_(i) ⁽²³⁾} 0 0 2 0 {ã_(i) ⁽³⁹⁾} −2 0 0 0 {ã_(i) ⁽⁵⁵⁾} −2 2 0 −2 {ã_(i) ⁽⁸⁾} 2 2 0 2 {ã_(i) ⁽²⁴⁾} 0 2 2 2 {ã_(i) ⁽⁴⁰⁾} 0 0 2 0 {ã_(i) ⁽⁵⁶⁾} 2 0 0 0 {ã_(i) ⁽⁹⁾} 2 0 0 0 {ã_(i) ⁽²⁵⁾} 0 0 2 0 {ã_(i) ⁽⁴¹⁾} 0 −2 2 −2 {ã_(i) ⁽⁵⁷⁾} 2 −2 0 −2 {ã_(i) ⁽¹⁰⁾} 2 2 −2 0 {ã_(i) ⁽²⁶⁾} 0 2 0 0 {ã_(i) ⁽⁴²⁾} 0 0 0 −2 {ã_(i) ⁽⁵⁸⁾} 2 0 −2 −2 {ã_(i) ⁽¹¹⁾} 2 0 −2 2 {ã_(i) ⁽²⁷⁾} 0 0 0 2 {ã_(i) ⁽⁴³⁾} 0 −2 0 0 {ã_(i) ⁽⁵⁹⁾} 2 −2 −2 0 {ã_(i) ⁽¹²⁾} 0 0 −2 0 {ã_(i) ⁽²⁸⁾} −2 0 0 0 {ã_(i) ⁽⁴⁴⁾} −2 −2 0 −2 {ã_(i) ⁽⁶⁰⁾} 0 −2 −2 −2 {ã_(i) ⁽¹³⁾} 0 2 −2 2 {ã_(i) ⁽²⁹⁾} −2 2 0 2 {ã_(i) ⁽⁴⁵⁾} −2 0 0 0 {ã_(i) ⁽⁶¹⁾} 0 0 −2 0 {ã_(i) ⁽¹⁴⁾} 0 0 0 2 {ã_(i) ⁽³⁰⁾} −2 0 2 2 {ã_(i) ⁽⁴⁶⁾} −2 −2 2 0 {ã_(i) ⁽⁶²⁾} 0 −2 0 0 {ã_(i) ⁽¹⁵⁾} 0 2 0 0 {ã_(i) ⁽³¹⁾} −2 2 2 0 {ã_(i) ⁽⁴⁷⁾} −2 0 2 −2 {ã_(i) ⁽⁶³⁾} 0 0 0 −2

[0080] A set of multilevel sequences is constructed by the addition of every sequence in {b⁽⁸⁾} with every sequence in {c⁽⁸⁾} as illustrated in Table 4.

[0081] For the MBCK example, there are (2n)^(m)=8²(=64) multilevel sequences each of length w=4. By applying the greatest peak criterion it is possible to select 32 multilevel sequences to be used as symbols in a 32-ary modulation scheme. The 32 multilevel sequences selected are shown in Table 4 as the shaded cells and the corresponding magnitudes of the greatest peak values at the correlator outputs are {6,6} for each symbol. A 32-ary modulation scheme is capable of encoding 5 bits per symbol. Hence, the bandwidth efficiency of this scheme is k/w=1.25.

[0082] MBCK uses the same demodulation scheme as MCK; that is, for the definition of n given MBCK requires just mn correlators. However, in MCK, either of the two maximum likelihood detection schemes discussed earlier can be used.

[0083] In the first scheme, each correlator output that corresponds to a valid subsequence is added to every other correlator output that also corresponds to a valid subsequence and hence a valid symbol. The addition is weighted according to the a priori known polarity of each subsequence; i.e. a weight of +1 for a positive subsequence and a weight of −1 for a negative (or complemented) subsequence. In this way a total of M test statistics are generated and fed to a gretest peak detector of size M. Since MBCK is a bi-code scheme like bi-orthogonal keying, then it is sufficient to generate just M/2 test statistics corresponding to one half of the symbol codebook; i.e. the addition of correlator outputs need only be done up to M/2 unique symbols. In this case the absolute values of the test statistics are fed to a gretest peak detector of size M/2. Then a symbol is uniquely detected by observing the greatest peak magnitude and its polarity before its absolute value was taken.

[0084] In the second scheme, the m sets of n test statistics are obtained using just mn correlators as in MCK. However, since MBCK is a bi-coding scheme which uses complementary sets of subsequences then the greatest peak magnitude is sought at the output of each bank of correlators and subsequently the polarity of each peak is used to identify whether or not the subsequence or its complement was detected. Then sufficient information is available to enable the look-up table to effect a correct decoding of the unique symbol transmitted. Once again, the second detection scheme is the preferred choice because it offers further substantial reductions in complexity without compromising the system BER performance.

[0085] The MBCK scheme presented in this example requires just eight correlators to detect the complementary symbols given in Table 4, as opposed to sixteen correlators when conventional 32-ary bi-code keying is used. This reduction in receiver complexity due to MBCK signaling is even more pronounced when n and m are large. Furthermore, though the sets of subsequences used in the examples are orthogonal this is not a requirement of either the MCK or MBCK shcemes. Non-orthogonal subsequence sets may be used which can give better system performance than orthogonal sets. In MCK and MBCK, since a multilevel sequence is constructed by the superposition of binary subsequences then distinct binary transmitters can be used to add subsequences directly on the channel thereby reducing the impairing effects of non-litearity at the transmitter.

[0086] In summary, it is worth noting that in conventional M-ary code keying a symbol is detected by a single bank of M=2^(k) correlators and a greatest peak detector of size M. Furthermore, in conventional M-ary code keying the sequences are typically orthogonal. In the new MBCK scheme proposed there are three distinct differences: (1) M=2^(k)≦(2n)^(m) means that the full set of multilevel sequences is not always used to transmit data thereby leaving redundant symbols that can be used to detect errors; (2) the total number of correlators required at the receiver is mn instead of M while just m greatest peak detectors of size n are required and (3) the subsequences need not be orthogonal. This results in a low complexity modulation scheme with good BER performance and good bandwidth efficiency. Though any set of binary subsequences may be used in MCK and MBCK Structured Codes prove to be particularly beneficial in this application. For both MCK and MBCK the main desirable properties of subsequence sets are that each subsequence should be:

[0087] cyclically distinct;

[0088] possess low autocorrelation sidelobes;

[0089] possess low intra-crosscorrelation magnitudes and

[0090] possess low inter-crosscorrelation magnitudes.

[0091] By intra-crosscorrelation is meant the crosscorrelation of subsequences belonging to the same set. By inter-crosscorrelation is meant the crosscorrelation of subsequences belonging to different sets. Subsequence sets that possess these properties benefit MCK and MBCK by producing large numbers of cyclically distinct symbols which in turn encode more bits per symbol thereby maximising the system bandwidth efficiency k/w. Structured codes are ideally suited to MCK and MBCK because they possess all of the above properties. For example, it is possible to construct four closely related sets of length 16 Structured Codes from the seed set {++−−, +−+−, −++−, −−−−}. For each set the intra-crosscorrelation magnitudes are zero (i.e. each set is orthogonal) while the inter-crosscorrelation magnitudes are given by {square root}16(=4) in all cases. In addition, the autocorrelation sidelobe magnitudes are upper bounded by {square root}16(=4) for every sequence of each set except the preset set. In a second example, it is possible to construct three closely related sets of length 12 Structured Codes from the seed set {++−−, +−+−, −++−}. In this case, the intra-crosscorrelation magnitudes for each set are upper bound by 4 (i.e. each set is non-orthogonal) while the inter-crosscorrelation magnitudes are also upper bounded by 4. In addition, the autocorrelation sidelobe magnitudes are upper bounded by 4 for every sequence of each set except the preset set. Furthermore, the sequences in all three sets are balanced which makes them ideally suited to the cancellation of narrowband common mode interference. To provide a full disclosure three illustrative examples of MBCK are presented. In the first, second and third examples, Structured Codes of lengths w=9, 12 and 16 are used, respectively.

EXAMPLE 1 w=9

[0092] Structured Codes of length w=9 can be constructed from the seed set {a⁽³⁾}={++−, +−+, −++}. Three sets of Structured Codes can be constructed corresponding to the a preset set and the addition tables {0 1 2, 1 2 0, 2 0 1} and {0 2 1, 2 1 0, 1 0 2} . Table 11 illustrates the three non-orthogonal sets of Structured Codes constructed. TABLE 11 Structured Codes w = 9 Preset Set Addition Table 1 Addition Table 2 + + − + + − − − + + + − + − + + − − + + − + − − + − + + − + + − + − + − + − + + − − + + − + − − + − + + + − − + + − + + + − − + − − + + − + − + + − + + + − + − − + + − − − + + + − + + − − + − − + + + + − − + + − + − + − + − + − + − + − + − − + + + + − − + + − + − + + − − + + + − − − + + − + + + + − − + − − + − + + − − + + − − + + + − + + − − − + + − + − + + − − + − + + + − + − + − + − + + − + + − + − + + − − + − + + + − + − − + + − − − + + − + + − + + − − + + − + + − + − − + − + +

[0093] The sets of Structured Codes presented in Table 11 can be used in an MBCK scheme as described in Section 3 with m=3, n=9 and w=9. In this case there are a total of (2n)^(m)=18³(=5832) multilevel sequences each of length w=9. It is possible to select 128(=2⁷) unique multilevel sequences which can be used as symbols in an 128-ary modulation scheme. Since an 128-ary modulation scheme is capable of encoding k=7 bits per symbol then the bandwidth efficiency of this scheme is k/w=0.78. The MBCK scheme presented in this example requires just mn=27 correlators (i.e. 3 banks of 9 correlators) instead of the M/2=64 correlators required in a conventional 512-ary bi-code keying scheme.

EXAMPLE 2 w=12

[0094] TABLE 12 Structured Codes w = 12 Preset Set Addition Table 1 Addition Table 2 + + − − + + − − − − + + + + − − + − + − + − − + + + − − + − − + + − + − + − + − + − + − − + − + + − + − + − − + + + − − + − − + + − + − + + − − − + + − − + + − + − − + + − − + + + − − + − + − + − + − + + − − + − − + + + − − − − + + + + − − + + − − − + − + − + + − + + − − − + + − − + − + + − + − − + − + + − + − − + − + − + + − + + − − − + + − − + − + + + − − − + + − + − − + − + + − − + + − + + − − − + − + − + − + + + − − − + + − − − + + + + − − + + − − − − + + + − + − − + + − − − + + − + + − + − + − − + − + + − + − + − + − + − + − − + + − − − + + − + + − + − + − − − + + + − − + − + + − − + + − − + + − − − + + + − + − + − + − − − + + − + + − − − + + − − + + − − + + − − + + − + − + + − − + − − + + + − − + − + − + − + − + − + − + − + − + − + − + + − − + − − + + + − − + − + − + − − + + + − − + + − − + + − − + + − − + − − + + − + − + − + − + − − + + + − − +

[0095] Structured Codes of length w=12 can be constructed from the seed set {a⁽³⁾}={++−−, +−+−, −++−}. Three sets of Structured Codes can be constructed corresponding to the preset set and the addition tables {0 1 2, 1 2 0, 2 0 1} and {0 2 1, 2 1 0, 1 0 2}. Table 12 illustrates the three non-orthogonal sets of Structured Codes constructed.

[0096] The sets of Structured Codes presented in Table 12 can be used in an MBCK scheme as described in Section 3 with m=3, n=12 and w=12. In this case there are a total of (2n)^(m)=24³(=13,824) multilevel sequences each of length w=12. It is possible to select 2048(=2 ¹¹) unique multilevel sequences which can be used as symbols in an 2048-ary modulation scheme. Since an 2048-ary modulation scheme is capable of encoding k=11 bits per symbol then the bandwidth efficiency of this scheme is k/w=0.9167. The MBCK scheme presented in this example requires just mn=36 correlators (i.e. 3 banks of 12 correlators) instead of the M/2=1024 correlators required in a conventional 2048-ary bi-code keying scheme.

EXAMPLE 3 w=16

[0097] Structured Codes of length w=16 can be constructed from the seed set {a⁽³⁾}={++−−, +−3+−,−++−, −−−−}. Four sets of Structured Codes can be constructed corresponding to the preset set and the additiontables {0 1 2 3, 1 0 3 2,2 3 0 1,3 2 1 0}, {0 2 3 1, 2 0 1 3,3 1 0 2, 1 3 2 0} and {0 3 1 2, 3 0 2 1, 1 2 0 3, 2 1 3 0}. Table 13 illustrates the four orthogonal sets of Structured Codes constructed. TABLE 13 Structured Codes w = 16 Preset Set Addition Table 1 Addition Table 2 Addition Table 3 + + − − + + − − − − + + − − + + + + − − + − + − + − − + + + + + + + − − + − − + + + + + + − + − + + − − + + + + + − + − + − − + + − + − + − + − − + − + − + − + + − + − + + − − + + + + + − − + + − − + + + − − + − + − + + + + + + + + + + − − + − − + + − + − − + + − − + + − + − − + + − − + + − − + + + + + + + − − + − + − + + + + + − + − + + − − + − − + + − + − + − − + + + − − + + + + − − − − − − − − + + + + + + + + + + + + + − − + + − + − + + − − + − + − + + + + + − − + + + − − + − − + + − + − + + + + + + − − + + − − − − + + + + − − − − + + + + − − − + − + − + + − + + + + + + − − − + + − + + + + − + − + + + − − + + + + − + − + − + + − + − + − − + − + + − + − − + − + − + − + + + − − + + + + − + + − − + + − + + − − − + − + + + + + + + + + + + − − − + + − − + − + − + + − + − − + − + + − + − − + − + + − + + + + + + − − − + − + + + + + − + − + + + − − − + + − − + − + − + + − + + − − + + + + − − − − + + + + − − − − + + + + + + + + − + + − − + − + + + − − − + − + + + + + − + + − + + − − − + + − − + − + + + + + + + − − − − + + + + − − + + − − − − + + − − + + + − + − − + + − + + + + − − + + − + + − + + + + + − + − − − + + + + + + + − + − − + + − − + − + + − + − + − + − − + − + + − + − − − + + + + + + − + + − − + + − − − + + + − + − + + + + + + + + − − + + − + + − + − + − + − + + − + + − − + + − + − − + − + + − + + + + − − + + + − + − + + + + + − + − − − + + − + + − + − + − − + + − − − + + + + + + + + + + − − − − − − − − + + + + + + + + − + + − + − + − − − + + + − + − + + + + − + + − − − + + − + + − + − + − + + + + − − + + − − + + − − + + − − + + − − + + − − + + − + − + + − − + + + + + − − + + + − − + + + + + − + − + − − + + + + + + − + − + + − − + − + − + − + − + − + − + − + − + − + − + − − + + + + + + + − − + + − − + − − + + − + − + + + + + + + + + − − + + + − − + − + − + + − − + + − − + + − − + + − − + + − − + + + + + − − + + − + − + + + + + − + − + − − + + + − − + − + − + + − − + − − + + + + + + + + + + + + + + + + + + + + + + + + + + + − − + − + − + − − + + − + − + + + + + + − − + − − + + + − − + − + − + + + + + − − + +

[0098] The sets of Structured Codes presented in Table 13 can be used in an MBCK scheme as described in Section 3 with m=4, n=16 and w=16. In this case there are a total of (2n)^(m)=32⁴(=1,048,576) multilevel sequences each of length w=16. It is possible to select 8192(=2¹³) unique multilevel sequences which can be used as symbols in an 8192-ary modulation scheme. Since an 8192-ary modulation scheme is capable of encoding k=13 bits per symbol then the bandwidth efficiency of this scheme is k/w=0.8125. The MBCK scheme requires just mn=64 correlators (i.e. 4 banks of 16 correlators) instead of the M/2=4096 correlators required in a conventional 8192-ary bi-code keying scheme.

[0099] It will be appreciated that though the specific embodiment described in this document relates to the use of (real) binary subsequences it should be realised that non-binary (real or complex) subsequences may be used without any loss of generality. That is, a multilevel sequence can be constructed by the superposition of multilevel subsequences.

[0100] It will of course be understood that the present invention is not limited to the specific details described herein, which are given by way of example only and that various modifications and alterations are possible within the scope of the appended claims. 

1. A method for data communication using spread spectrum techniques and multilevel sequences characterised in that selection distinct multilevel sequences used in the method contain binary subsequences that interfere constructively such that synchronous cross-correlation values add constructivly.
 2. A method as claimed in claim 1 utilising symbols, said symbols having a multilevel sequence constructed by adding together at least two subsequences taken from different sets.
 3. A method as claimed in claim 2 wherein a subsequence is provided as a binary sequence.
 4. A method as claimed in claim 2 or claim 3 including the step of detecting of a symbol for demodulation using an M-ary receiver.
 5. A method as claimed in claim 4 wherein the M-ary receiver incorporates a bank of M correlators in which: each M correlator is matched to a multilevel sequence; and forming a greatest peak detector of size M is to detect the symbol transmitted.
 6. A method as claimed in any of claims 2 to 5 in which a mulitlevel symbol is detected using a plurality of banks of predefined length correlators.
 7. A method as claimed in claim 6 wherein each predefined length correlator output is subjected to linear addition and analysed to identify a valid subsequence.
 8. A method as claimed in claim 7 utilising an amplitude demodulation process.
 9. A method as claimed in claim 8 wherein the amplitude demodulation process incorporates means for discriminating between different symbols having similar greatest peak positions.
 10. A method as claimed in claim 4 in which a symbol is detected using m-banks of n-correlators of predefined length.
 11. A method as claimed in claim 10 incorporating means for isolating a correlator output having a greatest peak from the bank of n correlators corresponding to the set from which the subsequence was taken.
 12. A method as claimed in any preceding claim in which a lookup table is used to decode data bits corresponding to a detected multilevel sequence.
 13. A method as claimed in any preceding claim wherein the multilevel sequences are constructed by adding together subsequences taken from complementary sets of binary sequences.
 14. A method as claimed in any preceding claim including the step of identifying sequences having the properties of being cyclically distinct and possessing: low autocorrelation sidelobes; low intra-crosscorrelation magnitudes; and low inter-crosscorrelation magnitudes.
 15. A data communications apparatus using spread spectrum techniques and multilevel sequences characterised in that the apparatus incorporates means for selection of distinct multilevel sequences containing constructively interfereing binary subsequences such that synchronous cross-correlation values add constructivly.
 16. A data communications apparatus as claimed in claim 15 incorporating means for detecting of a symbol for demodulation using an M-ary receiver.
 17. A data communications apparatus as claimed in claim 16 wherein the M-ary receiver incorporates a bank of M correlators in which: each M correlator is matched to a multilevel sequence; and forming a greatest peak detector of size M is to detect the symbol transmitted.
 18. A data communications apparatus as claimed claim 16 or 17 in which a mulitlevel symbol is detected using a plurality of banks of predefined length correlators.
 19. A data communications apparatus as claimed in claim 18 wherein each predefined length correlator output is subjected to linear addition and analysed to identify a valid subsequence.
 20. A data communications apparatus as claimed in claim 19 including an amplitude demodulator.
 21. A data communications apparatus as claimed in claim 20 wherein the amplitude demodulator includes means for discriminating between different symbols having similar greatest peak positions.
 22. A data communications apparatus as claimed in claim 16 in which the means for detecting a symbolincludes nm-banks of n-correlators of predefined length.
 23. A data communications apparatus incorporating means for isolating a correlator output having a greatest peak from the bank of n correlators corresponding to the set from which the subsequence was taken.
 24. A data communications apparatus as claimed in any of claims 15 to 23 including a lookup table for decoding data bits corresponding to a detected multilevel sequence.
 25. A data communications apparatus as claimed in any of claims 15 to 24 incorporating means for adding together subsequences taken from complementary sets of binary sequences to construct multilevel sequences. 